<%@ page pageEncoding="UTF-8"%>
<%@ include file="/common/common.jsp"%>
<%!
	public Map getMap(List<Map> result , Map<String,String> deptMap ){
		
		int sumCount = 0 ;
		//处理结合数据
		for(Map map : result){
			String ksdm = map.get("ksdm") == null ? "0" : map.get("ksdm").toString();
			map.put("deptName",deptMap.get(ksdm));
			sumCount++;
		}
		
		Map<String,Object> resMap = new HashMap<String,Object>();
		resMap.put("rank",result);
		resMap.put("sumCount",sumCount);
		return resMap;
	}
%>
<%
	//查询大费用
	String yydm =  input.getDesc("yydm","01");//医院代码	
	String ksdm = input.getDesc("ksdm","-1"); //传入科室代码代表该科室主任
	String date = input.getDesc("start_date","2018-01-06");//开始时间
	String endDa = input.getDesc("end_date","2018-12-24");//结束时间

	SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
	SimpleDateFormat sdf2 = new SimpleDateFormat("yyyyMMdd");
	String nowDate = sdf2.format(sdf.parse(date));
	String nowEndDa = sdf2.format(sdf.parse(endDa));
	
	String startDate = nowDate+"00:00:00";
	String endDate = nowEndDa+"23:59:59";

	String sqlWhere = " and js.jsrq > '"+ startDate + "' and js.jsrq < '" + endDate+"' " ;
	if(!yydm.equals("-1"))
	sqlWhere += " and js.ksdm in (select id  from his_dept where yydm ='"+yydm+"') " ;
	if(!"-1".equals(ksdm)){
		sqlWhere += " and js.ksdm in( " + ksdm + ")";
	}
	
	//获取所有科室
	List<Map> deptList = QBuilder.db("basedb").queryHql("select new map(id as id , name as name ) from his_dept ");
	Map<String,String> deptMap = new HashMap<String,String>();
	//科室放到map中 key-value(id-name)
	for(Map map : deptList){
		deptMap.put(map.get("id").toString(),map.get("name").toString());
	}
	
	
	//大费用病人明细

	
	
	List<Map> feelist = QBuilder.db("basedb").queryHql("select new map( sum(zje) as zje , ksdm as ksdm) from ZY_BRJSK js  where js.jlzt in (0,2)  and zje>50000  " + sqlWhere+ "  group by ksdm order by sum(zje) desc ");


	
	Map<String,Object> ma1 = new HashMap<String,Object>();

	ma1.put("ksMap",getMap(feelist , deptMap ));
	Message msg = new Message();

	msg.put("errcode",0);
	msg.put("big_charge",ma1);

	out.println(msg);
%>